home *** CD-ROM | disk | FTP | other *** search
/ Workbench Add-On / Workbench Add-On - Volume 1.iso / BBS-Archive / Comm / AmiTCP30b2.lha / netinclude / netinet / ip.h < prev    next >
C/C++ Source or Header  |  1993-08-01  |  6KB  |  192 lines

  1. /*
  2.  * $Id: ip.h,v 1.4 1993/06/30 05:45:25 jraja Exp $
  3.  *
  4.  * HISTORY
  5.  * $Log: ip.h,v $
  6.  * Revision 1.4  1993/06/30  05:45:25  jraja
  7.  * Changed bitfield definitions to be more like ANSI-C.
  8.  *
  9.  * Revision 1.3  1993/03/05  03:20:01  ppessi
  10.  * Compiles with SASC. Initial test version.
  11.  *
  12.  * Revision 1.2  93/03/03  21:39:09  21:39:09  jraja (Jarno Tapio Rajahalme)
  13.  * Added #ifdef to prevent multiple inclusion.
  14.  * 
  15.  * Revision 1.1  92/11/17  16:29:25  16:29:25  jraja (Jarno Tapio Rajahalme)
  16.  * Initial revision
  17.  * 
  18.  *
  19.  */
  20.  
  21. /*
  22.  * Copyright (c) 1982, 1986 Regents of the University of California.
  23.  * All rights reserved.
  24.  *
  25.  * Redistribution and use in source and binary forms, with or without
  26.  * modification, are permitted provided that the following conditions
  27.  * are met:
  28.  * 1. Redistributions of source code must retain the above copyright
  29.  *    notice, this list of conditions and the following disclaimer.
  30.  * 2. Redistributions in binary form must reproduce the above copyright
  31.  *    notice, this list of conditions and the following disclaimer in the
  32.  *    documentation and/or other materials provided with the distribution.
  33.  * 3. All advertising materials mentioning features or use of this software
  34.  *    must display the following acknowledgement:
  35.  *    This product includes software developed by the University of
  36.  *    California, Berkeley and its contributors.
  37.  * 4. Neither the name of the University nor the names of its contributors
  38.  *    may be used to endorse or promote products derived from this software
  39.  *    without specific prior written permission.
  40.  *
  41.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  42.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  43.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  44.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  45.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  46.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  47.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  48.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  49.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  50.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  51.  * SUCH DAMAGE.
  52.  *
  53.  *    @(#)ip.h    7.10 (Berkeley) 6/28/90
  54.  */
  55.  
  56. #ifndef IP_H
  57. #define IP_H
  58.  
  59. /*
  60.  * Definitions for internet protocol version 4.
  61.  * Per RFC 791, September 1981.
  62.  */
  63. #define    IPVERSION    4
  64.  
  65. /*
  66.  * Structure of an internet header, naked of options.
  67.  *
  68.  * We declare ip_len and ip_off to be short, rather than u_short
  69.  * pragmatically since otherwise unsigned comparisons can result
  70.  * against negative integers quite easily, and fail in subtle ways.
  71.  */
  72. struct ip {
  73. #if BYTE_ORDER == LITTLE_ENDIAN 
  74.     u_char    ip_hl:4;        /* header length */
  75.     u_char    ip_v:4;            /* version */
  76. #endif
  77. #if BYTE_ORDER == BIG_ENDIAN 
  78.     u_char    ip_v:4;            /* version */
  79.     u_char    ip_hl:4;        /* header length */
  80. #endif
  81.     u_char    ip_tos;            /* type of service */
  82.     short    ip_len;            /* total length */
  83.     u_short    ip_id;            /* identification */
  84.     short    ip_off;            /* fragment offset field */
  85. #define    IP_DF 0x4000            /* dont fragment flag */
  86. #define    IP_MF 0x2000            /* more fragments flag */
  87.     u_char    ip_ttl;            /* time to live */
  88.     u_char    ip_p;            /* protocol */
  89.     u_short    ip_sum;            /* checksum */
  90.     struct    in_addr ip_src,ip_dst;    /* source and dest address */
  91. };
  92.  
  93. #define    IP_MAXPACKET    65535        /* maximum packet size */
  94.  
  95. /*
  96.  * Definitions for IP type of service (ip_tos)
  97.  */
  98. #define    IPTOS_LOWDELAY        0x10
  99. #define    IPTOS_THROUGHPUT    0x08
  100. #define    IPTOS_RELIABILITY    0x04
  101.  
  102. /*
  103.  * Definitions for IP precedence (also in ip_tos) (hopefully unused)
  104.  */
  105. #define    IPTOS_PREC_NETCONTROL        0xe0
  106. #define    IPTOS_PREC_INTERNETCONTROL    0xc0
  107. #define    IPTOS_PREC_CRITIC_ECP        0xa0
  108. #define    IPTOS_PREC_FLASHOVERRIDE    0x80
  109. #define    IPTOS_PREC_FLASH        0x60
  110. #define    IPTOS_PREC_IMMEDIATE        0x40
  111. #define    IPTOS_PREC_PRIORITY        0x20
  112. #define    IPTOS_PREC_ROUTINE        0x10
  113.  
  114. /*
  115.  * Definitions for options.
  116.  */
  117. #define    IPOPT_COPIED(o)        ((o)&0x80)
  118. #define    IPOPT_CLASS(o)        ((o)&0x60)
  119. #define    IPOPT_NUMBER(o)        ((o)&0x1f)
  120.  
  121. #define    IPOPT_CONTROL        0x00
  122. #define    IPOPT_RESERVED1        0x20
  123. #define    IPOPT_DEBMEAS        0x40
  124. #define    IPOPT_RESERVED2        0x60
  125.  
  126. #define    IPOPT_EOL        0        /* end of option list */
  127. #define    IPOPT_NOP        1        /* no operation */
  128.  
  129. #define    IPOPT_RR        7        /* record packet route */
  130. #define    IPOPT_TS        68        /* timestamp */
  131. #define    IPOPT_SECURITY        130        /* provide s,c,h,tcc */
  132. #define    IPOPT_LSRR        131        /* loose source route */
  133. #define    IPOPT_SATID        136        /* satnet id */
  134. #define    IPOPT_SSRR        137        /* strict source route */
  135.  
  136. /*
  137.  * Offsets to fields in options other than EOL and NOP.
  138.  */
  139. #define    IPOPT_OPTVAL        0        /* option ID */
  140. #define    IPOPT_OLEN        1        /* option length */
  141. #define IPOPT_OFFSET        2        /* offset within option */
  142. #define    IPOPT_MINOFF        4        /* min value of above */
  143.  
  144. /*
  145.  * Time stamp option structure.
  146.  */
  147. struct    ip_timestamp {
  148.     u_char    ipt_code;        /* IPOPT_TS */
  149.     u_char    ipt_len;        /* size of structure (variable) */
  150.     u_char    ipt_ptr;        /* index of current entry */
  151. #if BYTE_ORDER == LITTLE_ENDIAN 
  152.     u_char    ipt_flg:4;        /* flags, see below */
  153.     u_char    ipt_oflw:4;        /* overflow counter */
  154. #endif
  155. #if BYTE_ORDER == BIG_ENDIAN 
  156.     u_char    ipt_oflw:4;        /* overflow counter */
  157.     u_char    ipt_flg:4;        /* flags, see below */
  158. #endif
  159.     union ipt_timestamp {
  160.         n_long    ipt_time[1];
  161.         struct    ipt_ta {
  162.             struct in_addr ipt_addr;
  163.             n_long ipt_time;
  164.         } ipt_ta[1];
  165.     } ipt_timestamp;
  166. };
  167.  
  168. /* flag bits for ipt_flg */
  169. #define    IPOPT_TS_TSONLY        0        /* timestamps only */
  170. #define    IPOPT_TS_TSANDADDR    1        /* timestamps and addresses */
  171. #define    IPOPT_TS_PRESPEC    3        /* specified modules only */
  172.  
  173. /* bits for security (not byte swapped) */
  174. #define    IPOPT_SECUR_UNCLASS    0x0000
  175. #define    IPOPT_SECUR_CONFID    0xf135
  176. #define    IPOPT_SECUR_EFTO    0x789a
  177. #define    IPOPT_SECUR_MMMM    0xbc4d
  178. #define    IPOPT_SECUR_RESTR    0xaf13
  179. #define    IPOPT_SECUR_SECRET    0xd788
  180. #define    IPOPT_SECUR_TOPSECRET    0x6bc5
  181.  
  182. /*
  183.  * Internet implementation parameters.
  184.  */
  185. #define    MAXTTL        255        /* maximum time to live (seconds) */
  186. #define    IPFRAGTTL    60        /* time to live for frags, slowhz */
  187. #define    IPTTLDEC    1        /* subtracted when forwarding */
  188.  
  189. #define    IP_MSS        576        /* default maximum segment size */
  190.  
  191. #endif     /* IP_H */
  192.